import { createApp } from 'vue'

import Cookies from 'js-cookie'

import ElementPlus from 'element-plus'
import locale from 'element-plus/lib/locale/lang/zh-cn' // 中文语言

import '@/assets/styles/index.scss' // global css

import App from './App'
import store from './store'
import router from './router'
import directive from './directive' // directive

// 防止多次点击
import preventReClick from './utils/preventReClick'

// 注册指令
import plugins from './plugins' // plugins
import { download, downloadforjson } from '@/utils/request'

// svg图标
import 'virtual:svg-icons-register'
import SvgIcon from '@/components/SvgIcon'
import elementIcons from '@/components/SvgIcon/svgicon'

import './permission' // permission control

import { parseTime, resetForm, addDateRange, addFieldsRange, handleTree, setNumberToFixed, setNumberToFixedThree, copyUrl, antiShake, newAddFieldsRange } from '@/utils/ruoyi'

import { numFilter } from "@/utils/common.js";

// 分页组件
import Pagination from '@/components/Pagination'
// 气泡组件
import Tooltip from '@/components/Tooltip'
const app = createApp(App)

// 全局方法挂载
app.config.globalProperties.download = download
app.config.globalProperties.downloadforjson = downloadforjson
app.config.globalProperties.parseTime = parseTime
app.config.globalProperties.resetForm = resetForm
app.config.globalProperties.copyUrl = copyUrl
app.config.globalProperties.handleTree = handleTree
app.config.globalProperties.addDateRange = addDateRange
app.config.globalProperties.addFieldsRange = addFieldsRange
app.config.globalProperties.newAddFieldsRange = newAddFieldsRange
app.config.globalProperties.setNumberToFixed = setNumberToFixed
app.config.globalProperties.setNumberToFixedThree = setNumberToFixedThree
app.config.globalProperties.antiShake = antiShake
app.config.globalProperties.numFilter = numFilter

// 全局组件挂载
app.component('Pagination', Pagination)
app.component('Tooltip', Tooltip)

app.use(router)
app.use(store)
app.use(plugins)
app.use(elementIcons)
app.component('svg-icon', SvgIcon)
app.use(preventReClick);

directive(app)

// 使用element-plus 并且设置全局的大小
app.use(ElementPlus, {
  locale: locale,
  // 支持 large、default、small
  size: Cookies.get('size') || 'default'
})

app.mount('#app')
